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SYSTEM AND METHOD FOR UPGRADING 
SOFTWARE IN A DISTRIBUTED COMPUTER SYSTEM 



FIELD OF THE INVENTION 

The present invention relates generally to the field of client/server (also known as 
.5 "distributed") computer systems. In particular, the present invention relates to a system and 
method for upgrading software, e.g., on a server, in a distributed computer system. 



BACKGROUND OF THE INVENTION 

The client/server computing model is a distributed computing model allowing a client 
process running on a client computer (a "client"), to delegate some of its work to a server 

10 process running on a server computer (a "server"). Distributed computer systems typically 
use multiple servers to provide essential functions to multiple users' clients in multiple 
concurrent user sessions. The use of multiple servers improves server availability and system 
capacity. It is often essential that distributed computer systems provide service on a 
continuously available, uninterrupted basis. However, distributed computer systems require 

15 periodic maintenance, including software upgrades. 

Figure 1 illustrates an exemplary distributed communications system 10 of the prior 
art. The system 10 includes three clients 12, 14, 16 connected to a communications network 
18, e.g. the Internet or an intranet. Also connected to the communications network 18 is a 
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server cluster 20 including application servers 22, 24 and 26. Each application server in the 
server cluster 20 stores an identical or nearly identical set of computer software programs and 
components thereof (collectively, "software"). Such software either enables a server to 
perform processes and/or interact with clients or is application software stored to be served to 
clients. An older version of such software is periodically replaced with a newer version 
providing new or more reliable functionality. This "upgraded" software must typically be 
installed on multiple servers in the distributed system. 

In operation, individual clients use software applications stored on the application 
servers by sending data packets among one another via the communications network. 
Clients send messages, or "requests" for the software and receive response messages from the 
servers. Individual requests are part of a "session." Application software starts and ends 
sessions. Since individual client's requests within a session may be routed to different 
application servers in the server cluster, some mechanism for sharing the session information 
is necessary. Various methods, both hardware and software based, are well known for 
sharing such information, including allowing access to shared memory or databases, and 
broadcasting session updates to all application servers in the cluster. For example, such 
information is typically stored in shared storage on an external data server 28. 

Each application server maintains a list of active client sessions (the "Active Session 
List") that it is currently supporting. Effectively, each entry in the Active Session List stores 
a unique session identification code ("session ID") and associated session data for each client 
session. When an application server detects a new client session, it writes a new entry to the 
Active Session List. At the end of a request, associated session data is written to the client. 
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Additionally, each application server stores information reflecting an active session count 
reflecting the number of active sessions being supported. 

Preferably, such Active Session Lists from each application server are compiled into 
a Session List maintained in a shared storage area, such as at an external data server 28 for 
5 returning data to the clients, as is well known in the art. When a next request from the client 
is to be serviced by a different application server, that application server reads the session ID 
from the Session List. The basic execution model is: receive client request, load session data 
from the Session List, process request, return response, write session to Session List. 

The application servers in the server cluster 20 are connected to the communications 
1 0 network 1 8 via a router 30. The router 30 and/or network routing layer functions in a well 
known manner, operating to distribute clients' requests among the multiple application 
servers. 

A system management server 32 is connected to the router 30 and each of the 
applications servers. The system management server stores a mapping of 

f 5 applications/software programs to application servers (the "Server List"). This mapping 

information is accessed by the router to complete routing functions. The system management 
server provides configuration and health/load information to the router of the 
communications network 18. 

There are several known architectures for distributed computer systems. One known 

20 example is the Java 2 Enterprise Edition specification of a client/server architecture (Java 2 
Enterprise Edition™ is a trademark of Sun Microsystems, Inc.). The Java 2 Enterprise 
Edition™ specification allows server vendors to support seamless migration of all ongoing 
client sessions from a first server to a second server to permit the first server to be removed 
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from the distributed computer system or by-passing an unscheduled server failure without 
aborting a pending client session. Figure 2 shows an exemplary flow diagram 50 depicting 
the process of upgrading software in the distributing computing system of Figure 1. 

As shown in Figure 2, the upgrade process begins with maintenance of the Session 
5 List and Server List, as shown at steps 51 and 52. There are many well known techniques for 
maintaining the Session List and Server List. Next, at step 54, an application server storing 
software to be upgraded is identified, e.g., Application Server 1. For example, the 
application server may be identified by reference to the Server List maintained in step 52. 

The system management server 32 then forbids the router to route client requests to 
10 Application Server 1, as shown at step 56, thereby removing Application Server 1 from 

active service during the upgrade procedure. For example, the system management server 32 
may send a signal to the router 30 with an appropriate message to cause the router 30 to stop 
sending new requests which could be serviced by the application server being upgraded. 
This may require an addition, deletion or modification to the Server List stored at the router 
15 and/or the system management server. 

The system management server 32 then monitors whether the application server is 
currently supporting any active client requests, as shown at step 58. For example, the system 
management server may send an appropriate signal to the application server to determine if 
the active session count is 0. If the application server is still supporting active client requests 
20 (i.e., the active session count is greater than 0), the system management server waits or 

continues polling, as shown at step 60. This continues until the active session count drops to 
0, indicating that the application server is no longer supporting any active client requests. 
Since the router will send no new requests to Application Server 1 and the current sessions 



_4_ 



Patent RSW9-2000-0119-US1 

have ended, Application Server 1 is effectively removed from the distributed computing 
system. 

At this point, Application Server 1 's software may be upgraded without disrupting 
any pending client requests. When the application server is no longer supporting any client 
5 requests, the appropriate software program on the appropriate application server is upgraded, 
as shown in step 62. Methods and computer hardware and software for upgrading software 
are well known in the art. 

Once the upgrade is complete, the system management server 32 then permits the 
router 30 to route new client requests to the Application Server 1, as shown at step 64. This 
1-0 may be achieved by addition, deletion or modification of the Server List. For example, step 
- 64 may be performed responsive to a signal sent from Application Server 1 to the system 

management server to indicate that the upgrade is complete. Finally, the method ends, as 
shown at step 65. In effect, the application server is added back to the distributed computing 
system. 

15 Accordingly, prior art methods remove all of an application server's resources from a 

distributed computing system in order to update a single software application, which may 
constitute a small fraction of the application server's stored applications. Accordingly, the 
distributed computer system's burden is increased during a software upgrade process because 
the system must service client's requests with one fewer application server. 

20 

SUMMARY OF THE INVENTION 

The present invention provides a system and method for upgrading software in a 
distributed computer system. Specifically, the present invention provides a system and 
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method for selectively redirecting or "migrating" only client sessions for the to-be-upgraded 
software. This is achieved by modifying software at the application server(s) and the system 
management server to cause the Server List to track servers capable of handling requests on 
the basis of each individual piece of software, and to cause the Session List to track requests 
5 on the basis of each individual piece of software. Accordingly, requests for only a specific 
piece of software can be migrated when only a small portion of an application server's 
resources need to be upgraded, the remainder of the application server's resources remaining 
available to the distributed computing system. In other words, the application server on 
which the software being upgraded resides can continue servicing requests for other pieces of 

ID software. As compared with prior art methods, the present invention reduces the burden on 
the distributed computing system during a software upgrade process. 

In accordance with the method, the application server is prevented from receiving any 
new requests for a particular computer program that needs to be upgraded. This is achieved 
by maintaining a mapping of computer programs to application servers and for a given 

1 5 server, instructing a router not to send requests for the particular computer program to the 
given server. The system then waits until all current requests serviced by the application 
server for that computer program have ended. This is achieved by tracking active client 
requests on the basis of each computer program; for the particular computer program, it is 
determined whether any client requests are currently active. Then, after acknowledging 

20 completion of upgrading of the computer program, the application server is permitted to 

receive any new requests for the computer program. For example, the application server may 
inform the system management server that the upgrade is complete, at which time the system 
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management server instructs the router that it may resume routing client requests for the 
particular computer program to the upgraded application server. 

In one embodiment of the present invention, the system management server includes 
software for systematically upgrading a plurality of servers so that the upgrade process 
5 "ripples" across the distributed computing system by refusing requests for the to-be- 
upgraded software sequentially for multiple servers. 

Apparatuses for carrying out the inventive method are provided. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 a block diagram of a distributed computing system in accordance with the prior 

1-0 art; 

Figure 2 is an exemplary flow diagram of a software upgrade method in accordance with 
the prior art; 

Figure 3 is an exemplary flow diagram of a software upgrade method in accordance with 
the present invention; 

15 Figure 4 is a block diagram of an application server in accordance with the present 

invention; and 

Figure 5 is a block diagram of an application server in accordance with the present 
invention. 

20 DETAILED DESCRIPTION 

The present invention provides a system and method for upgrading software in a 
distributed computer system including an application server storing to-be-upgraded software. 
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Prior art techniques tracked application server usage on a session basis and required an 
entire application server to be "quiesced", i.e., placed on an inactive status such that no new 
clients' requests for software stored by that application server could be routed to that 
application server during the upgrade process. Accordingly, the quiesced application server 
could not service any clients' requests. The present invention provides a system and method 
for permitting limited quiescence of an application server by tracking application server 
usage on a per application basis. Accordingly, an application server storing several software 
programs is permitted to continue servicing clients requests for software programs other than 
the to-be-upgraded software program while the to-be-upgraded software is upgraded. Only 
clients' requests for the to-be-upgraded software are routed away from the application server 
during the upgrade process. Accordingly, when only one software program stored on the 
application server needs to be upgraded, the remainder of the software programs stored on 
the application server remain available to the distributed computing system. As compared 
with prior art methods, the present invention therefore reduces the burden on the distributed 
computing system during a software upgrade process. 

Figure 3 is an exemplary flow diagram 70 of a software upgrade method in 
accordance with the present invention. As shown in Figure 3, the method begins with 
maintenance of a Session List and Server List, as shown at steps 71 and 72. This step differs 
from the prior art in that each entry in the Session List includes identification of the software 
program associated with the request, i.e., a mapping of each active request to each 
application. In one embodiment, the Session List is maintained only at each application 
server. In another embodiment, each application server's request list compiled into a master 
Session List at the external data server or in other shared storage. Any embodiment in which 
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it is apparent when the application server is no longer servicing a client's request for the 
computer program is suitable. 

Additionally, each entry in the Server List includes identification of the software 
programs on each application server, i.e., a mapping of each application to each application 
server. The Server List is preferably stored at the system management server and is used to 
provide the router 30 with a mapping of applications to application servers. This requires 
modification of software at the application servers and the system management server to 
track request/session information on a per application basis. For example, in the Internet 
context, the Session List may include a mapping of URL's for each software program to each 
server. Such mapping information is also stored in the Server List stored by the system 
management server. Alternatively, each software program may be identified by filename, 
transaction code, etc. 

An application server storing the to-be-upgraded ("TBU") software is then identified, 
as shown at step 74. This may be accomplished with or without human intervention, e.g., by 
observing which software programs are stored on a computer and checking for the to-be- 
upgraded software. Alternatively, an application server may be identified in an automated 
fashion by maintaining a database of software programs stored on each application server, 
the database being referenced by a software program for systematically checking and 
upgrading each application server in a server cluster, etc. For example, such a software 
program may be stored and executed at the system management server. 

Conceptually, once the TBU software has been identified at step 74, the router 30 is 
then forbidden to rout new client requests for the TBU software program to the to-be- 
upgraded application server, as shown at step 76. This step may be implemented, for 
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example, by sending an appropriate signal to the router 30 to indicate that requests for certain 
URL's cannot be routed to the TBU application server and/or by making an appropriate entry 
in the Server List stored at the system management server and/or router to indicate that the 
TBU application server is no longer accepting requests for the TBU software. Accordingly, 
5 when a new client's request for the TBU software is sent to the system management server, 
the Server List is consulted, and the request will be routed to an application server in the 
server cluster other than the TBU application server. 

The next step is to determine whether the TBU application server is currently 
supporting a client request for the software, as shown at step 78. This needs to be determined 
1-0 because the TBU software cannot be upgraded if the TBU application server is still 

supporting active client requests for the TBU software. This can be determined by reference 
to the Session List, which tracks requests on a per application basis. If the TBU application 
server is currently servicing a request for the software, the system waits, as shown at step 80. 
When the TBU application server is no longer servicing a request for the TBU software, the 
1 5 TBU software program is no longer in use and is ready to be upgraded. 

Accordingly, the software is upgraded on the TBU application server, as shown at 
step 82. This may be accomplished in any suitable manner, as is well-known in the art. 

Finally, the router 30 is permitted to route new client requests for the software to the 
application server storing the now-upgraded software, as shown at step 34, and the process 
20 ends, as shown at step 35. This may be accomplished by modifying the Server List stored at 
the system management server and/or router to reflect that the application server is no longer 
inactive or quiesced for client requests for the upgraded software. 

In this manner, clients' requests are continuously serviced, without interruption, 
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during the upgrade process, and with an overall reduced burden on the distributed computing 
system, as compared with prior art methods. 

In a preferred embodiment, these steps are carried out in an automated and systematic 
fashion by execution of a suitable computer software program such that upon completion of 
5 the upgrading of the software on a first application server, the method repeats for a second 
application server storing the to-be-upgraded software program. In this manner, the upgrade 
"ripples" across the server cluster. 

It should be understood that the present invention can also be used to upgrade not 
only the application software stored by an application server but also the server software 

10 itself. In such an embodiment, application software code is analyzed to determine a 

Components list and information is stored in the Server List and Session List to reflect which 
components of the server software is or will be used by to service the client's requests. The 
TBU component is then treated like application software for the purpose of the upgrade 
process in accordance with the present invention. When the server software is stored on an 

15 application server, the components list is generated to reflect the relationship of the 
components and how they will be used to service clients' requests for software. The 
Components List is preferably stored on the system management server. 

Figure 4 is a block diagram of an application server in accordance with the present 
invention. The hardware of the application server is of a type generally known in the art. 

20 The application server 100 includes a central processing unit ("CPU") 102, a memory 104, 
e.g., random access memory ("RAM"), read only memory ("ROM") and/or a storage device 
such as a hard disk drive, and a telecommunications device 1 06 for communicating via a 
communications network, e.g., using TCP/IP technology. The telecommunications device 
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may include a modem and/or a network card connected via a communications port 1 08. The 
application server may optionally include video display devices and/or input devices. 

The application server 100 stores in its memory a first program for storing in said 
memory a list of active client requests supported by said application server, a second 
program for storing in said memory an identification of a computer program associated with 
each active client request, a third program for identifying a computer program upon receipt 
of a signal via said telecommunications device, and a fourth program for sending a signal via 
said telecommunications device when said application server is no longer supporting an 
active client request for said computer program. 

Figure 5 is a block diagram of a system management server 150 in accordance with 
the present invention. The hardware of the system management server 150 is of the type 
generally known in the art. The system management server 150 includes a central 
processing unit ("CPU") 152, a memory 154, e.g., random access memory ("RAM"), read 
only memory ("ROM") and/or a storage device such as a hard disk drive, and a 
telecommunications device 156 for communicating via a communications network, e.g., 
using TCP/IP technology. The telecommunications device may include a modem and/or a 
network card connected via a communications port 158. The system management server 
150 may optionally include video display devices and/or input devices. 

The system management server 150 stores in its memory a first program for storing in 
said memory a list of application servers for servicing requests for a computer program, a 
second program for storing in said memory an identification of a computer program 
associated with each active client request, a third program for sending a signal via said 
telecommunications device to instruct a router to stop routing client requests for a particular 
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computer program to a particular application server, and a fourth program for sending a 
signal via said telecommunications device to instruct a router to begin routing client requests 
for said particular computer program to said particular application server responsive to an 
indication that an upgrade process of said particular computer program on said particular 
application server is complete. 

Having thus described a few particular embodiments of the invention, various 
alterations, modifications, and improvements will readily occur to those skilled in the art. 
Such alterations, modifications and improvements as are made obvious by this disclosure are 
intended to be part of this description though not expressly stated herein, and are intended to 
be within the spirit and scope of the invention. Accordingly, the foregoing description is by 
way of example only, and not limiting. The invention is limited only as defined in the 
following claims and equivalents thereto. 
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What is claimed is: 

1 . A method for upgrading at least one of a plurality of computer programs 
stored on an application server in a distributed computing environment, said method 
comprising: 

preventing said application server from servicing requests for an upgrade-ready 
computer program while permitting said application server to service client requests for other 
computer programs. 

2. The method of claim 1, further comprising the steps of: 

(a) preventing said application server from receiving any new requests for said 
computer program; 

(b) waiting until all of said application server's current requests for said computer 
program have ended; 

(c) acknowledging completion of upgrading of said computer program; and 

(d) permitting said application server to receive any new requests for said 
computer program. 

3. The method of claim 2, wherein step (a) comprises the step of: 

(e) sending a signal to a router to instruct said router to stop routing requests for 
said computer program to said application server. 

4. The method of claim 2, wherein said signal in step (e) comprises an 
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5. The method of claim 4, wherein said identification code comprises a universal 
resource locator. 

6. The method of claim 4, wherein said identification code comprises a filename. 

7. The method of claim 2, wherein step (d) comprises the step of: 

(f) sending a signal to a router to instruct said router to begin routing requests for 
said computer program to said application server. 

8. The method of claim 7, wherein said signal in step (f) includes an 
identification code identifying said computer program. 

9. The method of claim 2, wherein step (e) comprises the step of: 

(g) maintaining a server list, said server list identifying a computer program and 
an application server for satisfying a request for said computer program; and 

(h) identifying said computer program and said application server to said router. 

10. The method of claim 9, wherein said signal in step (f) comprises an 
identification code read from said server list. 

1 1 . The method of claim 2, further comprising the step of: 
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(i) maintaining a session list of active client requests serviced by said application 
server, said session list identifying a client request and a computer program requested by said 
client. 

12. The method of claim 11, wherein step (b) comprises the step of: 
(j) referencing said session list. 

13. The method of claim 2, further comprising the step of: 

(k) repeating steps (a) through (d) for a next application server storing said 
computer program. 

14. The method of claim 2, wherein step (c) comprises the step of: 

(1) receiving a signal from an application server upon completion of upgrading of 
said computer program at said application server. 

15. An application server for facilitating upgrading in a distributed computing 
environment, the application server comprising: 

a central processing unit; 

a memory operatively connected to said central processing unit; 

a telecommunications device operatively connected to said central processing unit 
and capable of communicating via a communications network; 

a first program stored in said memory and executable by said central processing unit 
for storing in said memory a list of active client requests supported by said application 
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server; 

a second program stored in said memory and executable by said central processing 
unit for storing in said memory an identification of a computer program associated with each- 
active client request; 

a third program stored in said memory and executable by said central processing unit 
for identifying a computer program upon receipt of a signal via said telecommunications 
device; and 

a fourth program stored in said memory and executable by said central processing 
unit for sending a signal via said telecommunications device when said application server is 
no longer supporting an active client request for said computer program. 

16. A system management server for facilitating upgrading in a distributed 
computing environment, the application server comprising: 
a central processing unit; 

a memory operatively connected to said central processing unit; 

a telecommunications device operatively connected to said central processing unit 
and capable of communicating via a communications network; 

a first program stored in said memory and executable by said central processing unit 
for storing in said memory a list of application servers for servicing requests for a computer 
program; 

a second program stored in said memory and executable by said central processing 
unit for storing in said memory an identification of a computer program associated with each 
active client request; 
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a third program stored in said memory and executable by said central processing unit 
for sending a signal via said telecommunications device to instruct a router to stop routing 
client requests for a particular computer program to a particular application server; and 

a fourth program stored in said memory and executable by said central processing 
unit for sending a signal via said telecommunications device to instruct a router to begin 
routing client requests for said particular computer program to said particular application 
server responsive to an indication that an upgrade process of said particular computer 
program on said particular application server is complete. 

17. A method for upgrading one of a plurality of computer programs stored on an 
application server in a distributed computing environment, said method comprising the steps 
of: 

(a) instructing a router to stop routing requests for said computer program to said 
application server; 

(b) waiting until said application server is no longer supporting a current client 
request for said computer program; 

(c) after completion of upgrading of said computer program, instructing said 
router to begin routing requests for said computer program to said application server. 

1 8. The method of claim 17, wherein step (a) comprises sending a signal to said 
router identifying said computer program and said application server, said signal comprising 
information retrieved from a server list and identifying said computer program. 
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19. The method of claim 17, wherein step (b) comprises receiving a signal from 
said application server, said application server maintaining a list of active client requests, 
said list identifying said computer program, said application server sending said signal when 
said list reflects no active client requests for said computer program. 

20. The method of claim 17, wherein step (c) comprises sending a signal to said 
router identifying said computer program and said application server, said signal comprising 
information retrieved from a server list and identifying said computer program. 
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SYSTEM AND METHOD FOR UPGRADING 
SOFTWARE IN A DISTRIBUTED COMPUTER SYSTEM 

ABSTRACT OF THE INVENTION 

A method for upgrading one of several computer programs stored on an application 
server in a distributed computing environment while permitting the application server to 
continue to service requests for other computer programs. In accordance with the method, 
the application server is prevented from receiving any new requests for the computer 
program. The system then waits until all current requests serviced by the application server 
for that computer program have ended. Then, after acknowledging completion of upgrading 
of the computer program, the application server is permitted to receive any new requests for 
the computer program. Apparatuses for carrying out the inventive method are provided. 
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As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name; I 
believe I am the original, first and sole inventor (if only one name is listed below) or an 
original, first and joint inventor (if plural names are listed below) of the subject matter which 
is claimed and for which a patent is sought on the invention entitled: 

SYSTEM AND METHOD FOR UPGRADING 
SOFTWARE IN A DISTRIBUTED COMPUTER SYSTEM 

the specification of which: 

I * \ is attached hereto. 

I j was filed on as Application Serial No . and 

was 

amended on . 



I hereby state that I have reviewed and understand the contents of the above- identified 
specification, including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose inforraation which is material to die patentability of this 
application in accordance with Title 37, Code of Federal Regulations, §1 .56. 

I hereby claim foreign priority benefits under Tide 35, United States Code, §119 of any 
foreign, application^) for patent or inventor's certificate listed below and have also 
identified below any foreign application forpaienr or inventor's certificate having a filing 
date before that of the application on which priority is claimed: 

Prior Foreign Application(s): 

Number Country Day/Month/Year Priority Claimed 



I hereby claim the benefit under Title 35, United States Code, §120 of any United States 
applicarion(s) listed below and, insofar as the subject matter of each of the claims of this 
application is not disclosed in the prior United States application in the manner provided by 
the first paragraph of Title 35, United States Code, §112, 1 acknowledge the dury to 
disclose information material to ihe patentabiliry of mis application as defined in Title 37, 
Code of Federal Regulations, §1.56 which occurred between the filing date of the prior 
application and the national or PCT international filing date of this application: 
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Prior U.S. Applications: 
S trial No. 



Filing Date 



Status 



I hereby declare that all statements made herein of my own knowledge are true and that all 
statements made on information and belief are believed 10 be true; and farther that these 
statements were made with me knowledge that willful false statements and the tike so made 
are punishable by fine or imprisonment, or boih, under Section 1001 of Title 18 of the 
United States Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 

As a named inventor, I hereby appoint the foEowing attorneys and/or agents to prosecute 




A.B. Clay 
G.M Doudnikoff 
E.H. Duffield 
J.W. Herndon 
J.S.Ray-Yartens 
John T. Synnestvedt 
Charles H. Lindrooth 
Alexis Barron 
Peter J. Butch, DI 
Joseph F. Posfllico 
Mark D. Simpson 
Theodore NaccareUa 



Patrick J. Kelly, Ph.D. 
Gary A. Hecht 
Stephen J. Driscoll 
Lisa B. Lane 
Joshua JR. Slavitt 
John A. Chionchio 
Gregory S. Bernabeo 
Stephen!. Weed 
Brett T. Freeman 
Esther Chong 
Gene J. Yao 



Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 
Reg. No. 



32,121 
32,847 
25,970 
27,901 
39,808 
18,117 
20,659 
22,702 
32,203 
32,290 
32,942 
33,023 
34,638 
36,826 
37,564 
38,217 
40,816 
40,954 
44,032 
45,202 
46,709 
40.953 
47,193 



PATENT 



Express Mail Label No. EL592133389US 
Docket No. RSW9-2000-OU9-US1 



Send all correspondence id: 

Gregory S. Bemabeo, Esquire 
Synneswedt & Lechner LLP 
2600 Aramark Tower 
1101 Market Street 
Philadelphia, PA 29107-2950 

Telephone: (215) 923-4466 
Facsinrile: (215) 923-2189 



(1) Inventor: Donald P. Ferguson . / 

Signature: fO^ jjA <IW^- Date: f & {/ D 

Residence: 2440 Pine Tree Place, Yorktown, NV 10598 / j, 

Citizenship: U.S.A. 

Post Office Address: Same as Residence 



(2) Inventor: Anand Byrappagari 

Signature: , Date:. 

Residence: 3102 Park Plaza Drive, Pittsburgh, PA 15229 
Citizenship: India 

Post Office Address: Same as Residence 



(3) Inventor: Graeme Dixon 

Signature: Date: 

Residence: 2214 Bond Street, Pittsburgh, PA 15237 

Citizenship: United Kingdom 

Post Office Address: Same as Residence 
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Declaration and Power of Attorney for 
Patent Application 



As a betow named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name; I 
believe I am the original, first and sole inventor (if only one name is listed below) or an 
original, first and joint inventor (if plural names are listed below) of the subject matter which 
is claimed and for which a parent is sought on the mventfon end [led: 

SYSTEM AND METHOD FOR UPGRADING 
SOFTWARE IN A DISTRIBUTED COMPUTER SYSTEM 

the specification of which; 

HH is attached hereto. 

1 1 was filed on as Application Serial No, and 

was 

amended on . 



I hereby state that I have reviewed and understand the contents of the above- identified 
specification, including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the patentability of this 
application in accordance with Title 37, Code of Federal Regulations, §1.56. 

I hereby claim foreign priority benefits under Tide 35, United States Code, §119 of any 
foreign appEcaiion(s) for patent or inventor's certificate listed below and have also 
identified below any foreign application for patent or inventor's certificate having a filing 
date before £hat of the application on which priority is claimed: " 

Prior Foreign Application(s): 

Number Country Day/Month/Year Priority Claimed 



I hereby claim the benefit under Title 35, United States Code. §120 of any United States 
applications) listed below and, insofar as the subject matter of each of the claims of this 
application is not disclosed in die prior United States application in the manner provided by 
the first paragraph of Title 35, United States Code, §112, 1 acknowledge the duty to 
disclose information material to the patentability of this application as defined in Title 37, 
Code of Federal Regulations, §1.56 which occurred between the filing date of the prior 
application and the national or PCT international filing date of this application: 
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Prior U.S. Applications: 
Serial No. 



Filing Date 



Status 



I hereby declare that all statements made herein of my own knowledge are tree and that all 
statements made on information and belief are believed ro be true; and further that these 
statements were made with the knowledge that willful false statements and the like so made 
are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the 
United States Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 

As a named inventor, I hereby appoint the following attorneys and/or agents to prosecute 
this application and transact all business in the Patent and Trademark Office connected 
therewith: 



A-B, Clay 
G.M. Doudnikoff 
E.H. Duffield 
J.W. Herndon 
J.S.Ray-Yarletts 
John T. Synnesrvedt 
Charles H. Lindrooch 
Alexis Barron 
Peter J. Butch> HI 
Joseph F. Posillico 
Mark D. Simpson 
Theodore Naccarella 
Patrick J. Kelly, Ph.D. 
Gary A. Hecbx 
Stephen J, Driscoll 
Lisa B. Lane 
Joshua R. Slavitt 
John A. Chionchio 
Gregory S. Bemabeo 
Stephen J. Weed 
Brett T. Freeman 
Esther Chong 
Gene J. Yao 



Reg. No. 32,121 
Reg. No. 32,847 
Reg. No. 25,970 
Reg. No. 27,901 
Reg. No, 39,80S 
Reg, No. 18,117 
Reg. No. 20,659 
Reg. NO. 22,702 
Reg. No. 32,203 
Reg. No. 32,290 
Reg. No. 32,942 
Reg. No. 33,023 
Reg. No, 34,638 
Reg, No. 36,826 
Reg. No. 37,564 
Reg. No. 38,217 
Reg. No. 40,816 
Reg. No. 40,954 
Reg, No. 44,032 
Reg. No. 45,202 
Reg. No. 46,709 
Reg. No. 40.953 
Reg. No. 47,193 
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Send all correspondence to: 

Gregory $, Bernabeo, Esquire 
Synnestvedc „ Leclmer LLP 
2600 Aramark Tower 
1101 Market Street 
Philadelphia, PA 19107-2950 

Telephone: (215) 923-4466 
Facsimile: (215) 923-2189 



(1) Mvemor: Donald F. Ferguson 

Signature: Date: 

Residence; 244ft Pine Tree Place, Yorktown, NY 1059S 
Citizeaaship: U.S.A. 

Post Office Address: Same as Residence 



(2) Inventor: Anand Byrappagari 

Signature: __ D_» 

Residence: 3102 Park Pl_a Drive, Pittsburgh, PA 15229 
Citizenship: India 

Post Office Address; Same as Residence 



(3) Inventor: Graeme 



Signature: , 

Residence: 2214 Bond Streets Pittsburgh, Pa 15237 
. CI_e_ship: United Kingdom 
Post Office Address: Same as Residence 



Date:. 
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Declaration and Power of Attorney for 
Patent Application 



As a below natnttd inventor, I hereby declare that: 

My residence, post office address and citizensMp are as stated below next to my name: T 
believe I am the original, first and sole inventor (if only one name is listed bejow) or an 
original, first and joint inventor (if plural names are listed below) of toe subject matter which 
is claimed and foi which a parem is sougnt on the invention erjjtttLed: 

SYSTEM AND METHOD FOR UPGRADING 
SOFTWARE IN A DISTRIBUTED COMPUTER SYSTEM 

the specification of winch: 

I ^ 1 is attached hereto. 

[~ I was filed on as Application Serial No. . and 

was 

amended on . 



I hereby state that I have reviewed and understand the contents of the above- identified 
specification, including the Claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the patentability of this 
application in accordance with Title 37, Code of Federal Regulations, §1 .56. 

I hereby claim foreign priority benefits under Title 35, United States Code r §119 of any 
foreign arjplicarirm(s) for patent or inventor's certificate lisied below and have also 
identified below any foreign application for patent or inventor's certificate having a filing 
date before that of the application on which priority is claimed: 

Prior Foreign Application^): 

Number Couniry Day /Month/Year Priority Claimed 



I hereby claim the benefit under Tide 35, United States Code, §120 of any United States 
appllcaiionCs) listed below and. insofar as tile subject matter of each of the claims of this 
application is not disclosed in the prior United States application in the manner provided by 
the first paragraph of Title 35, United Stares Code, §1 12, T acknowledge the rimy to 
disclose information material to the paisntabiliiy oF mis application as defined hi Title 37, 
Code of Federal Regulations, §1,56 wMch occurred between the filing date of the prior 
application and the national or PCT international filing date of this application: 
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Prior U.S. Applications: 
Serial No. 



Filing Date 



Status 



I hereby declare that all statements made herein of my own knowledge are tine and that all 
statements made on information and belief are believed to be true; and further that these 
sfarpruents -were made with the knowledge that willful false statements and the like so made 
are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the 
United States Code and that such willful false statements may jeopardize the v?»i«diry of tire 
application or any patent issued thereon. 

As a named inventor, I hereby appoint die following attorneys and/or agents to prosecute 
this application and transact all business in the Patent and Trademark Office connected 
therewith: 



A.B. Clay 
G.M. Doudnikoff 
E,H. Duffield 
J.W, Ilcmdon 
J.S.Ray-YarlettS 
John T. Synncsrvedt 
Charles H. Lindrooth 
Alexis Barron 
Peter J. Butch, III 
Josepn F. Posillieo 
Mark D. Simpson 
Theodore Naccarella 
Patrick J. Kelly, Ph.D. 
Gary A. Hecht 
Stephen J. DriscoM, 
Lisa B. Lane 
iosbua R. Slavitt 
John A. Chinnchirt 

Gregory S. Bernabeo 
Stephen J- Weed 
Brett T. Freeman 
Esther Chong 
Qc«e J. Ysiu 



Reg, No. 32,121 
Reg. No. 32,847 
Reg, No. 25,970 
Reg. No. 27,901 
Reg. No. 39,80$ 
Res. No. 1S.H7 
Reg. No. 20,659 
Reg. No. 22,702 
Reg, No. 32,203 
Reg. No. 32,290 
Reg. No. 32,942 
Reg. No. 33,023 
Reg. No. 34,638 
Reg. No. 36,826 
Reg. No. 37,564 
Reg. No, 38,217 
Reg. No. 40,816 
Reg. No. 40,954 
Reg. No. 44,032 
Reg. No. 45,202 
Reg. No. 46,709 
Reg. No. 40.953 
Reg. No. 47,193 
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Send all correspondence to: 

Gregory S. Beroabeo. Esquire 
Synnestvedr & Lechner LLP 
2600 Aramark Tower 
1101 Market Street 
. Philadelphia, PA 19107-2950 

Telephone: (215) 923^466 
Facsimile: (215) 923-2189 



(1) Inventor: Donald F. Ferguson 

Signature: Date: 
Residence: 2440 Pine Tree Place, Yorfctown, NY 10598 
Citizenship: U.S.A. 

Post Office Address: Same as Residence 



(2). Invenior: Anand Byrappagari 

Signature: 1%, jlLeuJl tu&e** _ Date: gf/^ QP 

Residence: 3102 Park Plaza Drive, Pittsburgh, PA 15229 
CitizensMp: India 

Post Office Address: Same as Residence 



(3) Investor: Graeme Dixon 

Signature: . Date: 

Residence: 2214 Bond Street, Plttsbuxgll, PA 15237 

Citizenship: United Kingdom 

Post Office Address: Same as Residence 



